[][src]Crate quinn_proto

Low-level protocol logic for the QUIC protoocol

quinn-proto contains a fully deterministic implementation of QUIC protocol logic. It contains no networking code and does not get any relevant timestamps from the operating system. Most users may want to use the futures-based quinn API instead.

The quinn-proto API might be of interest if you want to use it from a C or C++ project through C bindings or if you want to use a different event loop than the one tokio provides.

The most important types are Endpoint, which conceptually represents the protocol state for a single socket and mostly manages configuration and dispatches incoming datagrams to the related Connection. Connection types contain the bulk of the protocol logic related to managing a single connection and all the related state (such as streams).

Re-exports

pub use crypto::rustls::AuthenticationData;

Modules

crypto

Traits and implementations for the QUIC cryptography protocol

generic

Types that are generic over the crypto protocol implementation

transport_parameters

QUIC connection transport parameters

Structs

ApplicationClose

Reason given by an application for closing the connection

Certificate

A single TLS certificate

CertificateChain

A chain of signed TLS certificates ending the one to be used by a server

ConnectionClose

Reason given by the transport for closing the connection

ConnectionEvent

Events sent from an Endpoint to a Connection

ConnectionHandle

Internal identifier for a Connection currently associated with an endpoint

ConnectionId

Protocol-level identifier for a connection.

Datagram

An unreliable datagram

EndpointEvent

Events sent from a Connection to an Endpoint

ParseError

Errors encountered while parsing a TLS certificate or private key

PrivateKey

The private key of a TLS certificate to be used by a server

StreamId

Identifier for a stream within a particular connection

Transmit

An outgoing packet

TransportConfig

Parameters governing the core QUIC state machine

TransportError

Transport-level errors occur when a peer violates the protocol specification

TransportErrorCode

Transport-level error code

UnknownStream

Unknown stream ID

VarInt

An integer less than 2^62

VarIntBoundsExceeded

Error returned when constructing a VarInt from a value >= 2^62

Enums

ConfigError

Errors in the configuration of an endpoint

ConnectError

Errors in the parameters being used to create a new connection

ConnectionError

Reasons why a connection might be lost.

DatagramEvent

Event resulting from processing a single datagram

Dir

Whether a stream communicates data in both directions or only from the initiator

EcnCodepoint

Explicit congestion notification codepoint

Event

Events of interest to the application

FinishError

Reasons why attempting to finish a stream might fail

ReadError

Errors triggered when reading from a recv stream

SendDatagramError

Errors that can arise when sending a datagram

Side

Whether an endpoint was the initiator of a connection

WriteError

Errors triggered while writing to a send stream

Type Definitions

ClientConfig

A ClientConfig containing client-side rustls configuration

Connection

A Connection using rustls for the cryptography protocol

Endpoint

An Endpoint using rustls for the cryptography protocol

EndpointConfig

A EndpointConfig using rustls keys

ServerConfig

A ServerConfig containing server-side rustls configuration